<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>绑定样式</title>
  <script src="../js/vue.js"></script>
  <style>
    .basic {
      width: 400px;
      height: 100px;
      border: 1px solid black;
    }
    .happy {
      border: 4px solid red;
      background-color: rgba(255, 255, 0, .644);
      background: linear-gradient(30deg, yellow, pink, orange, yellow);
    }
    .sad {
      border: 4px solid green;
      background-color: gray;
    }
    .normal {
      background-color: skyblue;
    }
    .s1 {
      background-color: yellowgreen;
    }
    .s2 {
      font-size: 30px;
      text-shadow: 2px 2px 10px red;
    }
    .s3 {
      border-radius: 20px;
    }
  </style>
</head>
<body>
  <!-- 
    绑定样式：
      1. class样式
        写法： :class="xxx" xxx可以是字符串、对象、数组。
            字符串写法适用于：类名不确定，要动态获取。
            数组写法适用于：要绑定多个样式，个数不确定，名字也不确定。
            对象写法适用于：要绑定多个样式，个数确定，名字也确定，但不确定用不用。
      2. style样式
        :style="{fontSize: xxx}" 其中xxx是动态值
        :style="[a, b]" 其中a,b是样式对象。
   -->
  <div id="root">
    <!-- 绑定class样式--字符串写法，适用于：样式的类名不确定，需要动态指定 -->
    <div class="basic" :class="mood" @click="changeMood">{{name}}</div><br/><br/>
    <!-- 绑定class样式--数组写法，适用于：要绑定的样式个数不确定、名字也不确定 -->
    <div class="basic" :class="classArr">{{name}}</div><br/><br/>
    <!-- 绑定class样式--对象写法，适用于：要绑定的样式个数确定、名字也确定，但要动态决定用不用 -->
    <div class="basic" :class="classObj">{{name}}</div><br/><br/>

    <!-- 绑定style样式--对象写法 -->
    <div class="basic" :style="styleObj">{{name}}</div><br/><br/>
    <!-- 绑定style样式--数组写法 -->
    <div class="basic" :style="styleArr">{{name}}</div>
  </div>
  <script>
    Vue.config.productionTip = false; // 阻止vue在启动时生成生产提示。
    const vm = new Vue({
      el: "#root",
      data: {
        name: '名字',
        mood: 'normal',
        classArr: ['s1', 's2', 's3'],
        classObj: {
          s1: false,
          s2: false
        },
        styleObj: {
          fontSize: '40px'
        },
        styleArr: [
          {
            fontSize: '30px',
            color: 'orange'
          }
        ]
      },
      methods: {
        changeMood() {
          // document.getElementById('demo').className = 'basic happy'
          // this.mood = 'happy'
          const arr = ['happy', 'sad', 'normal']
          this.mood = arr[Math.floor(Math.random()*3)]
        }
      }
    })
  </script>
</body>
</html>